草庐IT

中文字符的PHP urlencode

全部标签

ruby - 给定字符串的所有可能排列?

我如何在Ruby中执行此操作?p"abc".all_possible_permutations会返回:["abc","acb","bca","bac","cba","cab",]编辑感谢JakubHampl:classStringdefall_possible_permutationsself.chars.to_a.permutation.map(&:join)endend 最佳答案 %w[abc].permutation.map&:join 关于ruby-给定字符串的所有可能排列?,我

ruby-on-rails - 在 Ruby 中计算字符串中单词的最佳方法?

有什么比string.scan(/(\w|-)+/).size更好的吗(-就是这样,例如,“单向street"算作2个词而不是3)? 最佳答案 string.split.size编辑解释多个空格来自RubyStringDocumentationpagesplit(pattern=$;,[limit])→anArrayDividesstrintosubstringsbasedonadelimiter,returninganarrayofthesesubstrings.IfpatternisaString,thenitscontents

ruby - 在 Ruby 中转义和取消转义字符串的最佳方法?

Ruby是否有任何内置方法来转义和非转义字符串?过去,我使用正则表达式;然而,我突然想到Ruby可能一直在内部进行此类转换。也许这个功能暴露在某个地方。到目前为止,我已经想出了这些功能。他们工作,但他们似乎有点hacky:defescape(s)s.inspect[1..-2]enddefunescape(s)eval%Q{"#{s}"}end有没有更好的办法? 最佳答案 添加了Ruby2.5String#undump作为String#dump的补充:$irbirb(main):001:0>dumped_newline="\n".d

ruby - Nokogiri、open-uri 和 Unicode 字符

我正在使用Nokogiri和open-uri来抓取网页上标题标签的内容,但在处理重音字符时遇到了问题。处理这些问题的最佳方法是什么?这是我正在做的:require'open-uri'require'nokogiri'doc=Nokogiri::HTML(open(link))title=doc.at_css("title")此时,标题看起来是这样的:Rag\303\271代替:Ragù我怎样才能让nokogiri返回正确的字符(例如本例中的ù)?这是一个示例网址:http://www.epicurious.com/recipes/food/views/Tagliatelle-with-

Ruby:在字符处拆分字符串,从右侧算起

简短版本——如何在ruby​​中执行Pythonrsplit()?更长的版本--如果我想在第一个'.'处将字符串分成两部分(名称、后缀)性格,这很好地完成了工作:name,suffix=name.split('.',2)但如果我想在最后(最右边)'.'处拆分角色,我想不出比这更优雅的东西了:idx=name.rindex('.')name,suffix=name[0..idx-1],name[idx+1..-1]ifidx请注意,原始名称字符串可能根本没有点,在这种情况下,名称应保持不变,后缀应为零;它也可能有一个以上的点,在这种情况下,只有最后一个点之后的一位应该是后缀。

ruby-on-rails - Ruby 2.0.0 字符串#Match ArgumentError : invalid byte sequence in UTF-8

我经常看到这种情况,但还没有想出一个优雅的解决方案。如果用户输入包含无效的字节序列,我需要能够让它不引发异常。例如:#@raw_responsecomesfromuserandcontainsinvalidUTF-8#forexample:@raw_response="\xBF"regex.match(@raw_response)ArgumentError:invalidbytesequenceinUTF-8已经问了很多类似的问题,结果似乎是对字符串进行编码或强制编码。然而,这些都不适合我:regex.match(@raw_response.force_encoding("UTF-8"

Ruby 转义 ARGV 参数或字符串作为 shell 命令的参数

好吧,这让我发疯:`ls#{"/media/music/MilesDavis"}`由于“Miles”和“Davis”之间的空格而失败假设我编写了一个ruby​​脚本,用户将文件路径作为参数传递。我如何转义它并提供给shell-out命令。是的,是的,我知道,应该避免掏空。但这是一个人为的例子,我仍然需要这个。我会做system("ls",ARGV[0]),但它不会将ls的标准输出输出作为字符串返回,这正是反引号擅长的地方。如何转义你在shellout中插入的任何内容? 最佳答案 使用require'shellwords'和Shell

ruby - 将字符串截断为前 n 个单词

将字符串截断为前n个单词的最佳方法是什么? 最佳答案 n=3str="yourlonglonginputstringorwhatever"str.split[0...n].join('')=>"yourlonglong"str.split[0...n]#notethattherearethreedots,whichexcludesn=>["your","long","long"] 关于ruby-将字符串截断为前n个单词,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - 将 Rails 中的主键更改为字符串

所以我有两个模型,State和Acquisition。状态has_many收购。我觉得51条记录的自动递增整数主键相当愚蠢。所以我将州的模型更改为PK(州是两个字母的缩写;我没有在任何地方存储实际的州名称:classState问题是当我创建采集模型时,它将外键列state_id创建为一个整数。更具体地说,脚本/生成的迁移做了:classCreateAcquisitions我假设t.references数据类型将其设置为int。问题是我的Acquisition类上的创建方法试图将状态缩写放入表acquisitions的state_id字段中(是的,它在数据库上称为state_id,即使它

ruby - ruby 1.9 中有没有办法从字符串中删除无效的字节序列?

假设你有一个像"€foo\xA0"这样的字符串,编码为UTF-8,有没有办法从这个字符串中删除无效的字节序列?(所以你得到"€foo")在ruby​​-1.8中,您可以使用Iconv.iconv('UTF-8//IGNORE','UTF-8',"€foo\xA0")但现在已弃用。"€foo\xA0".encode('UTF-8')不执行任何操作,因为它已经是UTF-8。我试过:"€foo\xA0".force_encoding('BINARY').encode('UTF-8',:undef=>:replace,:replace=>'')产生“foo”但这也丢失了有效的多字节字符€